草庐IT

android - 将参数传递给 GcmTaskService

全部标签

pointers - 为什么在将它传递给另一个函数时需要指向 Go bytes.Buffer 的指针?

在下面的代码中,write_commas要求缓冲区参数是一个指针。它有效。替代方案(即不使用指针)会导致空白输出。为什么传递实际的bytes.Buffer无法打印任何内容?或者换句话说,传递实际的bytes.Buffer是否会创建一个副本,从而将字节写入一个没有任何内容正在读取的缓冲区?packagemainimport("fmt""bytes")funcmain(){s:="1234567898"fmt.Println(Comma(s))}funcComma(sstring)string{varbufbytes.Buffer//0{whole_part:=sbytes[:decima

go - 我应该在哪个函数中传递 WaitGroup?

我做了一个简单的代码示例来理解pipeline的用法,就在这里。packagemainimport("fmt""sync""time")funcmain(){ch1:=make(chanint,10)//Usebufferedchannelsoastoavoidcloggingch2:=make(chanstring,10)varwgsync.WaitGroupfori:=0;i现在,问题是我没有得到一致的输出(我知道这是一些并发问题,我还没有完全理解)。输出>gorunpipeline-loop.go012hellohello>gorunpipeline-loop.go012hell

go - 带有接口(interface)参数不兼容错误的类型函数

我已经声明了一个新类型func,它采用符合interface{}的任何值。但是,当我调用一个作为参数传递的函数(符合该类型规范)时,我得到一个错误。有人能解释一下为什么会这样吗?下面是我可以重现问题的最简单示例。typemyfuncfunc(xinterface{})funca(numint){return}funcb(fmyfunc){f(2)return}funcmain(){b(a)//error:cannotusea(typefunc(int))astypemyfuncinargumenttobreturn} 最佳答案 您在

go - 如何为以文件路径作为参数的golang方法提供Windows完整路径

所有golang方法都说ioutil.ReadFile理解unix路径,但它不采用windows路径。有没有办法以优雅的方式实现这一点,以便这些方法可以同时采用unix和windows路径。 最佳答案 您也可以在Windows中使用“/”。示例代码如下。packagemainimport("fmt""io/ioutil""log")funcmain(){content,err:=ioutil.ReadFile("D:/temp/main.go")iferr!=nil{log.Fatal(err)}fmt.Printf("Fileco

go - 不能在 db.Query 的参数中使用缓冲区(类型 bytes.Buffer)作为类型字符串

我在buffer.WriteString()中编写了一个SQL查询,但无法在db.Query()中使用该缓冲区。buffer.WriteString(fmt.Sprintf(`SELECTc.id,c.company_name,ss.start_date,ss.shift_length,ss.bill_rate,ss.ot_hrs,ss.dt_hrs,ts.pay_rate,ts.wc_rate,ts.paid,td.wcFROMcompanycJOINusersu1ONc.id=u1.company_idJOINschedulesONu1.id=s.user_idJOINschedu

go - 如何强制编译器控制值/值指针函数参数?

处理go的函数时,我发现在使用“通用”接口(interface){}类型时,无法强制编译器控制我是传递值参数还是值指针参数。funcf(ointerface{}){...}最明显的解决方案是使用以下修改:funcf(o*interface{}){...}虽然编译成功了,但我发现这一步不对。那么,有什么方法可以表明我想传递任何指针? 最佳答案 你必须使用reflection.import"reflect"funcf(ointerface{}){if_,ok:=reflect.Typeof(o).(*reflect.PtrType);!

go - 将映射传递给导入的 Golang 包中的函数时出错

我需要将映射发送到导入包中声明的函数,并不断收到此错误:./main.go:21:cannotusem(typemap[string]ticket)astypemap[string]some_package.ticketinfunctionargument这是golangGOPATH文件夹中main.go的代码:packagemainimport("time"sp"./some_package")typeticketstruct{Timestampint64Identification_numberint}varmmap[string]ticketfuncmain(){humans:=

Go函数参数

func(db*Database)VerifyEmail(emailAddressstring)(*data.UserName,error){....}有人可以帮助澄清1.what和2.why上面的功能吗?来自docs和thisbook我可以看出VerifyEmail将emailAdress作为参数,并将我认为是内存地址的内容返回给用户名。但是,(db*Database)是做什么的呢?我的意思是为什么要把它放在func之后和函数名称之前?将内存地址作为指针而不是代表它的变量传递给函数的原因可能是什么? 最佳答案 方法名前面的(*db

go - 是否可以在 Go 中将结构作为参数传递?

我正在尝试将一组键、值传递给Go中的另一个函数。对Go很陌生,所以我正在努力弄清楚。packagemainimport("net/http""fmt""io/ioutil""net/url")typeParamsstruct{items[]KeyValue}typeKeyValuestruct{keystringvaluestring}funcmain(){data:=[]Params{KeyValue{key:"title",value:"Thingy"},KeyValue{key:"body",value:"Testing123"}}response,error:=makePost

reflection - 如何获取在 GO 中的 func() 参数中传递的参数值?

我正在尝试在路由中创建中间件,想知道如何获取在func()参数中传递的参数值。例如:func(cappContainer)Get(pathstring,fnfunc(rwhttp.ResponseWriter,req*http.Request)){//HOWDOIGETTHEVALUESOFrwANDreqPASSEDINfnfunc()?c.providers[ROUTER].(Routable).Get(path,fn)}我查看了反射文档,但我不清楚,或者也许有更简单的方法?已编辑(解决方案)事实证明不需要反射(reflection),正如Adam在对这篇文章的回复中以及Jason